$(function () {
  var layer = layui.layer;
  var form = layui.form;
  var laypage = layui.laypage;

  // 定义美化时间过滤器
  template.defaults.imports.dataFormat = function (date) {
    const dt = new Date(date);

    var y = dt.getFullYear();
    var m = padZero(dt.getMonth() + 1);
    var d = padZero(dt.getDate());
    var hh = padZero(dt.getHours());
    var mm = padZero(dt.getMinutes());
    var ss = padZero(dt.getSeconds());

    return y + '-' + m + '-' + d + ' ' + hh + ':' + mm + ':' + ss;
  };

  // 定义时间补0函数
  function padZero(n) {
    return n > 9 ? n : '0' + n;
  }

  // 查询参数对象，请求数据时需要将其发送到服务器
  var q = {
    pagenum: 1, //页码值，默认请求第一页数据
    pagesize: 2, //每页显示几条数据，默认每页显示两条
    cate_id: '', //文章分类id
    state: '', //文章分类状态
  };

  initTable();
  initCate();

  // 获取文章列表方法
  function initTable() {
    $.ajax({
      method: 'GET',
      url: '/my/article/list',
      data: q,
      success: function (res) {
        if (res.status !== 0) {
          return layer.msg('获取文章列表失败！');
        }
        // 使用模板引擎渲染页面数据
        console.log(res);
        var htmlStr = template('tpl-table', res);
        $('tbody').html(htmlStr);
        // 调用渲染分页方法
        renderPage(res.total);
      },
    });
  }

  // 初始化文章分类方法
  function initCate() {
    $.ajax({
      method: 'GET',
      url: '/my/article/cates',
      success: function (res) {
        if (res.status !== 0) {
          return layer.msg('获取分类数据失败！');
        }
        // 调用模板引擎渲染分类可选项
        var htmlStr = template('tpl-cate', res);
        $('[name=cate-id]').html(htmlStr);
        // 通知layui重新渲染表单区域ui结构
        form.render();
      },
    });
  }

  // 为筛选表单绑定submit事件
  $('#form-search').on('submit', function (e) {
    e.preventDefault();
    // 获取表单中选中的值
    var cate_id = $('[name=cate-id]').val();
    var state = $('[name=state]').val();
    // 为查询参数对象q中对应属性赋值
    q.cate_id = cate_id;
    q.state = state;
    // 根据最新筛选条件，重新渲染表格数据
    initTable();
  });

  // 定义渲染分页
  function renderPage(total) {
    // 调用laypage.render()方法来渲染分页结构
    laypage.render({
      elem: 'pageBox', //分页容器id
      count: total, //数据总数
      limit: q.pagesize, //每页显示几条数据
      curr: q.pagenum, //指定默认显示的分页
      layout: ['count', 'limit', 'prev', 'page', 'next', 'skip'],
      limits: [2, 3, 5, 10],
      // 分页发生切换时触发jump回调
      // 触发jump回调的方式有两种
      // 1.点击页码的时候，会触发jump回调
      // 2.调用laypage.render就会触发回调
      jump: function (obj, first) {
        // 可以通过first的值，来判断是通过哪种方式触发的jump回调
        // 如果first的值是true，则是上面第二种方式触发
        // 否则就是方式一
        // 把最新的页码值,赋值到q这个查询参数对象中
        q.pagenum = obj.curr;
        // 把最新条目数赋值给q中pagesize
        q.pagesize = obj.limit;
        // 根据最新的q获取对应列表数据，并渲染表格
        if (!first) {
          initTable();
        }
      },
    });
  }

  // 通过代理形式为删除按钮绑定点击事件处理函数
  $('tbody').on('click', '.btn-delete', function () {
    // 获取删除按钮个数
    var len = $('.btn-delete').length;
    // 获取文章id
    var id = $(this).attr('data-id');
    layer.confirm('确认删除?', { icon: 3, title: '提示' }, function (index) {
      $.ajax({
        method: 'GET',
        url: '/my/article/delete/' + id,
        success: function (res) {
          if (res.status !== 0) {
            return layer.msg('删除失败！');
          }
          layer.msg('删除成功！');
          // 当数据删除完成后，判断当前页是否还有剩余数据，没有数据让页码值-1，再重新调用initTable方法
          if (len === 1) {
            // 如果leng等于1，则删除完毕之后页面没有数据
            // 页码值最小必须为1
            q.pagenum = q.pagenum === 1 ? 1 : q.pagenum - 1;
          }
          initTable();
        },
      });

      layer.close(index);
    });
  });

  // 通过代理形式为编辑按钮绑定点击事件处理函数
  $('tbody').on('click', '.btn-edit', function () {
    var id = $(this).attr('data-id');
    $.ajax({
      method: 'GET',
      url: '/my/article/' + id,
      success: function (res) {
        if (res.status !== 0) {
          return layer.msg('获取文章详情失败！');
        }
        console.log(res);
        var data = JSON.stringify(res.data);
        localStorage.setItem('data', data);
        location.href = '/article/art_edit.html';
      },
    });
  });
});
